package com.example.foodwebbackend.mapper;

import com.example.foodwebbackend.entity.UserRating;
import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Param;

import java.util.List;
import java.util.Map;

@Mapper
public interface UserRatingMapper {
    
    /**
     * 根据用户ID分页查询评价
     */
    List<UserRating> findByUserId(@Param("userId") Integer userId, 
                                 @Param("offset") Integer offset, 
                                 @Param("limit") Integer limit);
    
    /**
     * 统计用户评价总数
     */
    Integer countByUserId(@Param("userId") Integer userId);
    
    /**
     * 添加评价
     */
    int insert(UserRating userRating);
    
    /**
     * 根据ID删除评价
     */
    int deleteById(@Param("ratingId") Integer ratingId);
    
    /**
     * 根据用户ID和菜品ID查询评价
     */
    UserRating findByUserIdAndFoodId(@Param("userId") Integer userId, @Param("foodId") Integer foodId);
    
    /**
     * 更新评价
     */
    int update(UserRating userRating);
    
    /**
     * 获取菜品的所有评价信息
     */
    List<Map<String, Object>> findFoodReviews(@Param("foodId") Integer foodId);
} 